<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>02_外间距测试</title>
    <style>
        /* 去掉body自带的8px外间距 */
        body {
            margin: 0;
        }
        /* 去掉所有元素自带的内外间距 */
        * {
            margin: 0;
            padding: 0;
        }
        .fu {
            background-color: rgba(255, 255, 0, .3);
            /*2.父子贴边:首个子元素的上外间距与最后一个元素的下外间距会超出父元素的范围
            解决：给父元素设置BFC结界保护 */
            overflow: hidden;
        }
        .fu>div {
            width: 100px; /* 设置元素宽度 */
            height: 100px;/* 设置元素高度 */
            background-color: rgba(0,0,255,.6);/* 设置元素背景色，不透明度0.6 */
            border: 2px solid #00f;/* 设置元素边框 2px的蓝色单实线边框 */
            color: #fff;/* 设置文字颜色 */
            font-size: 25px;/* 设置字号 */
            font-weight: bold;/* 设置字重：加粗 */
        }
        /* 1.相邻兄弟在垂直方向的外间距取最大值显示，并不会累加 */
        .z1 {
            margin-bottom: 30px;
            margin-top: 50px;
        }
        .z2 {
            margin-top: 50px;
        }
        .z4 {
            margin-bottom: 50px;
        }
        .z3 {
            margin: 10px; /* 四个方向的外间距都是10px */
            margin: 10px 20px; /* 上下10 左右20 */
            margin: 10px 20px 30px; /* 上10 左右20 下30 */
            margin: 10px 20px 30px 40px; /* 上10 右20 下30 左40 顺时针依次赋值*/
            /* 实现块级元素自身的水平居中 auto会自动将元素的左右外间距计算成相等的值 */
            margin: 0 auto;
        }
        span {
            border: 2px solid #f00;
        }
        .s2 {
            /*3. 行内元素垂直方向上的外间距不成效！*/
            margin: 30px;
        }
    </style>
</head>
<body>
    <span>span1</span><span class="s2">span2</span><span>span3</span>
    <!--选中代码按Tab可以一起缩进 Shift+Tab可以回退缩进-->
    <!--.fu>.z*4-->
    <div class="fu">
        <div class="z1">子元素1</div>
        <div class="z2">子元素2</div>
        <div class="z3">子元素3</div>
        <div class="z4">子元素4</div>
    </div>
</body>
</html>